import Vue from 'vue'
import VueRouter from 'vue-router'
import HomeView from '../views/Home.vue'
import store from '@/store'

Vue.use(VueRouter)

const routes = [{
    path: '/',
    redirect: '/home'
  },
  {
    path: '/home',
    name: 'home',
    component: HomeView
  },
  {
    path: '/goods',
    name: 'goods',
    component: () => import('../views/Goods.vue')
  },
  {
    path: '/user',
    name: 'user',
    component: () => import('../views/User.vue'),
    redirect: '/user/cart',
    children: [{
      path: 'cart',
      component: () => import('../components/user/Cart.vue'),
    }]
    //只有访问当前路由时 触发该钩子函数
    // beforeEnter: (to, from, next) => {
    //   console.log("访问了......");
    //   //(只有个人中心进行校验)如果用户没有登录，则不能打开个人中心页面。
    //   let token = localStorage.getItem('x-auth-token');
    //   if (token) {
    //     next();
    //   } else {
    //     // alert('你还没有登录！');
    //     store.dispatch('showToast/asyncIsShowToast', {
    //       isshow: true,
    //       msg: '你还没有登录',
    //       type: 'danger'
    //     })
    //   }
    // }

  },
  {
    path: '/order',
    name: 'order',
    component: () => import('../views/Order.vue')
  },
  {
    path: '/free',
    name: 'free',
    component: () => import('../views/Free.vue')
  },
  {
    path: '/details',
    name: 'details',
    component: () => import('../views/Details.vue')
  },
  //404配置
  {
    path: "*",
    name: 'error',
    component: () => import('../components/Error.vue')
  }
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  routes
})
//全局前置守卫
/* 
   to: Route: 即将要进入的目标 路由对象   (准备打开哪个页面)
 from: Route: 当前导航正要离开的路由 
 next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数。 */
//何时执行？每次路由切换之前执行该钩子函数...
// router.beforeEach((to, from, next) => {

//   console.log('beforeEach****************', to, from);
//   if (to.path == '/user') {
//     //(只有个人中心进行校验)如果用户没有登录，则不能打开个人中心页面。
//     let token = localStorage.getItem('x-auth-token');
//     if (token) {
//       next();
//     } else {
//       // alert('你还没有登录！');
//       store.dispatch('showToast/asyncIsShowToast', {
//         isshow: true,
//         msg: '你还没有登录',
//         type: 'danger'
//       })
//     }
//   } else {
//     next();
//   }

// })

const originalPush = VueRouter.prototype.push;
VueRouter.prototype.push = function (location) {
  return originalPush.call(this, location).catch(err => {})
};

export default router